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2 О СЕБЕ 


РХОМ!С 


е Лилия Крючкова 
е Серверная разработка 
е )а\уа, эса!а 


е В Рхопс с 2017 года 


НЕ) НЕНГоаа"" 


=} ЧЕГО НЕ БУДЕТ В ДОКЛАДЕ 


е Архитектура проекта 
е Настройка БД 


е Настройка облаков 


РХОМ!С (НЕ) Ниньова" 


Старт проекта — 2015 
ОРАУ 480К 


ССУ З0К 


| РХОМ!С 


=} УСПЕХ ММАВ ВОВОТ$ 2016 ГОДА 


РХОМ!С (НЕ) Нньова" 


=} ГРАФИК ВЫРУЧКИ 2016-2017 


РХОМ!С (НЕ) Ниньова" 


=} ЧТО ТАКОЕ «ПРЯМАЯ ПОКУПКА» 


® Покупка за реальные деньги 
е Контент: монетки 
е Не очень интересна игрокам 


е Продуктов не может быть бесконечно много 


Р!ХОМ!С НЕ) ННоаа"* 


=} ЧТО ТАКОЕ «ОФФЕР» 


е Контент: роботы, пушки 


(© 24ч45м 


а Скидки 1) Миготет: 
е Интересны игрокам р 
е Доступны не всегда, есть время активности 
е Доступны по критериям 


® Могут быть ограничения на количество 
покупок КУПИТЬ 


Р!ХОМ!С НЕ) Нноаа"* 


= ГРАФИК ВЫРУЧКИ 2016-2017 


РХОМ!С 


2} ТРЕБОВАНИЯ БИЗНЕСА К ОФФЕРНОЙ 
СИСТЕМЕ МЕЧТЫ 


® Выдаются по различным событиям игрока 
® Рассчитаны на разные группы игроков 

© Предлагают контент различного типа 

о 1000+ 


е Покупка как за внутриигровую валюту, так и за реальные деньги 


Р1ХОМ!С (НЕ) Ниньова" 


& ТРЕБОВАНИЯ КОМАНДЫ РАЗРАБОТКИ 
К ОФФЕРНОИ СИСТЕМЕ МЕЧТЫ 


е Не требует участия разработчика при добавлении 
оффера на новый контент 


е Быстрая 


е Легко расширяемая 


РХОМ!С (НЕ) Нньова" 


= ПОТЕНЦИАЛЬНАЯ НАГРУЗКА 


ССУ ЗОк 
Офферов 1000+ 
ЗоОк * 1000 = 30000к 


е Система критична для проекта 


е Должно работать быстро 


РХОМ!С (НЕ) Ниньова" 


2} ТРЕБОВАНИЯ БИЗНЕСА К ОФФЕРНОЙ 
СИСТЕМЕ МЕЧТЫ 


Ш} © Выдаются по различным событиям игрока 
® Рассчитаны на разные группы игроков 
© Предлагают контент различного типа 
о 1000+ 


е Покупка как за внутриигровую валюту, так и за реальные деньги 


Р1ХОМ!С (НЕ) Ниньова" 


= ЧТО МОЖЕТ ЗАПУСТИТЬ ВЫДАЧУ ОФФЕРА 


Триггеры: 

® При логине 

е При повышении уровня 

е При получении робота/пушки 


е При вступлении в лигу 


Потенциально при любом изменении состояния игрока 


РХОМ!С (НЕ) Ниньова" 


= КОНФИГ ОФФЕРОВ 


$Р_2М\|_1000аи_40т$ой ОМ Г Е\МЕЕ_ЧР 


БР_4М| СИИ _падпит_{агап ОМ_ЕМТЕК _САКАСЕ 
5Р_5М| Г апсе!о*_огкап ОМ_КОВОТ_ОВТА1М 


ЗР_6\М|_@СгИЯп_ТщитвБа$_рт ОМ_)01М_ 1ЕАСИЕ 


5Р_6\[_5000аи ОМ_\МТЕМ/ \ТРЕО_АБ 


5Р_7М1_Ригу_7еи$ ОМ_ВЕТУВКМ_РКОМ_ОРРЕЫМЕ 


РХОМ!С (НЕ) Нньоаа" 


= ЭЛЕМЕНТЫ ООМА1ТМ ОВТУЕМ ОЕЗТСМ 


Изоляция контекстов 

е® Модель ответственна за изменение своего состояния 

® Доступ к модели через изолированные сервисы 

® Взаимодействие контекстов на уровне бизнес-сценария 


Изменение состояния моделей с помощью событий 


РХОМ!С (НЕ) Нньова" 


= ДОМЕНЫ ИГРОКА 


Контентные домены 
е Роботы 
е Пушки 


Служебные домены 
е Офферы 

е Платежи 

е Бои игрока 

е Пуши 


РХОМ!С (НЕ) Ниньова" 


= ДОМЕНЫ ИГРОКА 


Контентные домены 


Модель роботов игрока 


е Роботы 

® Пушки [[бььиь ЗЕМ 
[тоне | "ЗЕЯ 
[вне — ЕЕ! 


Служебные домены 


е Офферы 
е Платежи 
е Бои игрока 


Р!ХОМ!С (НЕ) Ниньова" 


= ДОМЕНЫ ИГРОКА 


Контентные домены 
е Роботы 
е Пушки оо и 


[вонь 
[жевеь 
Служебные домены 


е Офферы 
е Платежи 
е Бои игрока 


РХОМ!С (НЕ) Нньова" 


= ДОМЕНЫ ИГРОКА 


Контентные домены 
е Роботы 
е Пушки 


Служебные домены 
е Офферы 

е Платежи 

е Бои игрока 

е Пуши 


РХОМ!С 


м добавить 
я прокачать 
м продать 


Модель роботов игрока 


АааВоБо*Еуеп* 


Рег! {ег 


= ДОМЕНЫ ИГРОКА 


Контентные домены 
е Роботы 
е Пушки 


Служебные домены 
е Офферы 

е Платежи 

е Бои игрока 

е Пуши 


РХОМ!С 


АааВоБо*Еуеп* 
зоба | = АООТ _ 
Г теонеь | 
[—екеь 


- 
- 


Модель роботов игрока 


Рег! {ег 


15 ДОМЕНЫ ИГРОКА о о на 


Контентные домены 


Модель роботов игрока 


е Роботы 


е Пушки о 


[вонь 
[ жевеь 
Служебные домены 


е Офферы 

е Платежи 

е Бои игрока 
е Пуши 


РХОМ!С 


2 ДОМЕН ОФФЕРОВ 


Атрибуты оффера игрока: 
е Рауе Та 

е ОНеа 

е Сгеатед АЕ 

е \/аПАТо 

ое Кеад АЕ 


Операции с оффером: 
е Выдать 
е Пометить прочитанным 
е Купить 


РХОМ!С (НЕ) Ниньова" 


=} САЗЗАМОКА В КАЧЕСТВЕ БД 


о Кеу/\а|ие-хранение данных 
е Быстрая запись 


е Нет полноценного АС 


РХОМ!С (НЕ) Ниньова" 


& ЧТО ЗНАЧИТ КЕУ/УАГУОЕ ХРАНЕНИЕ 


РХОМ!С (НЕ) Ниньова" 


& ЧТО ЗНАЧИТ КЕУ/УАГУОЕ ХРАНЕНИЕ 


Кеу1 


Кеу2 


РХОМ!С 


\/аие1 


\/аие2 


Ра юоп Кеу 
+ \а!ие1_1 
Си${егтд Кеу 


Ра юп Кеу 
+ \а!ие2_1 
Си${егтд Кеу 


\а!ие1_2 


\а!ие2_2 


(но) НЕНГоаа* 


=} КАК МЫ ХРАНИМ ДАННЫЕ 


Схема 1 


Ра" юп Кеу | Си$егтд Кеу авиьще1 акибще2 ре И 
(Р!ауег Та) (СопкепЕ Та) Е Е. И 


РХОМ!С (НЕ) Ниньова" 


=} КАК МЫ ХРАНИМ ДАННЫЕ 


Схема 1 


РагИ оп Кеу | Сизегпд Кеу ацирще1 ацибще2 ре И 


(Р!ауег 14) (СопкепЕ 1а) опад\аие э&ипа\а!ие р 


Схема 2 


Ра юоп Кеу Сиегта Кеу 


(Р!ауег Та) (авньше 1) аа 


Ра оп Кеу Си$егтд Кеу . 
(Рауег 1а) (авньше 2) й 5епа\а!ие 


Ра оп Кеу Сиегта Кеу 
(Рауег Та) и) 


РХОМ!С (НЕ) Ниньова" 


=} КАК МЫ ХРАНИМ ДАННЫЕ 


Схема 1 


РагИ оп Кеу | Сизегпд Кеу акибие1 ацище2 ИИ 


(Р!ауег 14) (СопкепЕ 1а) опад\аие 5&ипа\а!ие р 


Схема 2 
Ра ют Кеу Сиегта Кеу ЕЕ ® Запись атома рна 
(Р!ауег 1а) (авнбще 1) |. в рамках партиции 


Ра оп Кеу Сиегта Кеу 
(Рауег Та) и) 


Ра| оп Кеу | Си$еппд Кеу 
(Рауег 1а) (авньше 2) й 5епа\а!ие 


РХОМ!С (НЕ) Ниньова" 


2} НАША СХЕМА ХРАНЕНИЯ 


е Унифицированные запись и чтение 


® Гарантия консистентности данных в партиции 


РХОМ!С (НЕ) Ниньова" 


=} СХЕМА ХРАНЕНИЯ ДАННЫХ ОФФЕРА 


ОНЙег ЕпКу 


Раг оп Кеу Е - {"сгеаедА"": 166573752000 


"уаНаТо": 166576752000, 
Р1ауег 14а ОНег 19 геаЧАЕ: 1665737720003 


ОНег Ригспазе ЕпКу 


Ра оп Кеу Сиегта Кеу 
{"Ете": 166573752000, 
Р!ауег Та ОПета* "уаНато": 166576752000} 


ТгапзасНЧопТа 


РХОМ!С (НЕ) Ниньоваа" 


=} КАК МЫ ПИШЕМ ДАННЫЕ 


Кед!${гайоп ь 


Паттерн Цп® о{ М/огК 


е Собирает изменения 


М/ай Гог 
гед!гаНоп 


Сотти 


е Координирует запись 


Что-то похожее на транзакцию 


Рег ег 


РХОМ!С (НЕ) Ниньоваа" 


=} КАК МТ ОЕ МОВК РЕАЛИЗОВАН У НАС 


ОпЁ оЁ могК 


Ш Зарегистрировать 


№ Зафиксировать 


АЧааВоБо{ЕуепЕ5 и сгЬег 


Р!ХОМС (НЕ) Манова" 


=} КАК МТ ОЕ МОВК РЕАЛИЗОВАН У НАС 


ОпЁ оЁ могК 


еаиь | События | г | события _ 
Роботов События Модель | События 


Ш Зарегистрировать 


№ Зафиксировать 


АЧааВоБо{ЕуепЕ5 и сгЬег 


Р!ХОМС (НЕ) Ниньова" 


=} КАК 9МПТ ОЕ \ММОВК РЕАЛИЗОВАН У НАС 


ее | События г | события _ 
РоботбВ События Модель 1 События 
Зарегистрировать 


УрдгадевоБо{ЕуепЕ 


№ Зафиксировать 


АЧааВоБо{ЕуепЕ5 и сгЬег 


Р!ХОМС (НЕ) Ниньова" 


=} КАК 9МТ ОЕ МОВК РЕАЛИЗОВАН У НАС 


ОпЁ оЁ могК 


Модели 


рооов | События | Г | События ___ 
Роботов События Модель | События 
МЕ | 
| УрдгадевоБо{ЕуепЕ 


События 
модели 
роботов 


Загруженные 
модели 


—_—_—__ АааВоБо{ЕуепЕ5 и снег 
Еуеп+25ибсирег 


РХОМ!С (НЕ) Ниньова" 


= НЕМНОГО ПРО НАШУ АРХИТЕКТУРУ 


Балансировщик 


НТТГР 
Ргое 
бегусе 


е НТГТР ])ауа-сервера 


е Саз5апага 


е Балансировщик Коипа КоБп НТТР 


Ргое 
бегмусе 


Ргое 
бегмусе 


Р!ХОМ!С (НЕ) Нньова" 


2} ЧТО ЖЕ С КОНКУРЕНТНОЙ ЗАПИСЬЮ 


е Синхронизация — дорого 
е Са55апага пишет быстро 


е Идемпотентный результат бизнес-сценария 


РХОМ!С (НЕ) Ниньоаа" 


=} ПРИМЕР ОФФЕРА 


е Оффер 
о ОНета $Р_6 М Безнпег 
е Робот 


о КобоНа Ве пег 


РХОМ!С (НЕ) Ниньова" 


& БИЗНЕС-СЦЕНАРИЙ «ВЫДАТЬ ОФФЕР» 


® Изолированно в рамках домена 


НТТР 


Ргое Зег\се 


ОНегАадедЕуепЕ 


РХОМ!С (НЕ) Ниньова" 


& БИЗНЕС-СЦЕНАРИЙ «ВЫДАТЬ ОФФЕР» 


® Изолированно в рамках домена 


РгоШе 5егмсе Рауета = "Ийснка" 


ОоНена = "5Р_6 М Безптег" 
ОНегАдадедЕуепЕ 


\УаЙаТо = 166573752000 


Саз5апага 


ОНег Еп у 
Рагюп Кеу Сизегпд Кеу 


ИйсВКа БР_6 М! _Рез{нег 


РХОМ!С (НЕ) Ниньова" 


{"сгеаеаА*": 166573752000, 
"уайаТо": 166576752000, 
геад АЕ: пи} 


& БИЗНЕС-СЦЕНАРИЙ «ВЫДАТЬ ОФФЕР» 


® Изолированно в рамках домена 


е Оффер с идентификатором оНета может быть только один 


РгоШе 5егмсе Р!ауета = "Ийснка" 


ОоНена = "5Р_6 М Безптег" 


Сгеа{еаде = 166573752000 


\МайЙаТо = 166573752000 
ОНегАадедЕуепЕ 


Саз5апага 


ОНег Еп у 
Рагюп Кеу Сизегпд Кеу 


ИйсВКа БР_6 М! _Рез{нег 


РХОМ!С (НЕ) Ниньова" 


{"сгеаеаА*": 166573752000, 
"уайаТо": 166576752000, 
геааАЕ: пи} 


& БИЗНЕС-СЦЕНАРИЙ «ВЫДАТЬ ОФФЕР» 


® Изолированно в рамках домена 


е Оффер с идентификатором оНета может быть только один 


Рауета = "ЕспКа" 
ОоНена = "5Р_6 М Безптег" 
\МайАТо = 1665737520000 
ОНегАдаедЕуепЕ 


Саз5апага 


ОНег Еп у 
Ргое Зег\се Раг оп Кеу Си$етпа Кеу 


ОНегАадедЕуепте Р!ауета = "Шйснка" 


оНена = "5Р_6 М Безпег" 
Сгеа{еаА* = 166573782000 
\МаНаТо = 166573752000 


РХОМ!С (НЕ) Ниньова" 


{"сгеаеаА*": 166573752000, 
"уайаТо": 166576752000, 
геааАЕ: пи} 


& БИЗНЕС-СЦЕНАРИЙ «ВЫДАТЬ ОФФЕР» 


® Изолированно в рамках домена 


е Оффер с идентификатором оНета может быть только один 


е Идемпотентно 


Рауета = "ЕспКа" 
ОоНена = "5Р_6 М Безптег" 


\МайаТо = 166573752000 
ОНегАадедЕуепЕ 


Саз5апага 


ОНег Еп у 
Ргое Зег\се Раг оп Кеу Си$етпа Кеу 


ОНегАадедЕуепте Р!ауета = "Шйснка" 


оНена = "5Р_6 М Безпег" 
Сгеа{еаА* = 166573782000 
\МаНаТо = 166573752000 


РХОМ!С (НЕ) Ниньова" 


{"сгеаеаА*": 166573752000, 
"уайаТо": 166576752000, 
геааАЕ: пи} 


& БИЗНЕС-СЦЕНАРИЙ «ВЫДАТЬ ОФФЕР» 


® Изолированно в рамках домена 


е Оффер с идентификатором оНета может быть только один 


е Идемпотентно 


Рауета = "Ыснка"_ й 
стеаневль > 16573752000 е Не требует синхронизации 


\МайаТо = 166573752000 
ОНегАадедЕуепЕ 


Саз$5апага 


ОНег Еп у 
Ргое Зег\се Раг оп Кеу Си$етпа Кеу 


ОНегАадедЕуепте Р!ауета = "Шйснка" 


оНена = "5Р_6 М Безпег" 
Сгеа{еаА* = 166573782000 
\МаНаТо = 166573752000 


РХОМ!С (НЕ) Ниньова" 


{"сгеаеаА*": 166573752000, 
"уайаТо": 166576752000, 
геааАЕ: пи} 


& БИЗНЕС-СЦЕНАРИЙ «ОФФЕР ПРОЧИТАН» 


® Изолированно в рамках домена 


е Оффер с идентификатором оНеа может быть только один 


е Идемпотентно 


Рауета = "Е спКа" 


События Омен = "ЗР_6М_резбтег" е Не требует синхронизации 
ВеааАЕ = 166573752000 
ОНегВеаЧЕ\уепЕ 


Саз5апага 


ОНег Еп у 
Ргое Зег\се Раг оп Кеу Си$етпа Кеу 


ОНегВеадЕ\уепе Рауеа = "Шиснка" 


ОНена = "5Р_6 М Безпег" 
КеаадЕ = 166573782000 


{"сгеаеаА*": 166573752000, 
"уаП!аТо": 166576752000, 
геааАЕ: 1665737520003 


РХОМ!С (НЕ) Нньова" 


28 БИЗНЕС-СЦЕНАРИЙ «КУПИТЬ ОФФЕР» 


Затрагивает много доменов 


е Офферы 


е Роботы 


Рго е З5егуег 


ОНегРигспазедЕуепЕ 
ВоБо*АаадеаЕуепЕ 


РХОМ!С (НЕ) Нньова" 


2} КОНКУРЕНТНАЯ ЗАПИСЬ ПЛАТЕЖЕЙ ОФФЕРОВ 


е Идемпотентно 


Ргое Зегмсе 


Рауета = "ИйспКа" 
ОНета = "5Р_6 М Безег#ТгапзасНопТа" 
ОНегРигспазеЯЕмепЕ 


Саз$5апага 


ОНег Ригсвазе ЕпКу 
Рагюп Кеу Сизегпд Кеу 


т ЗР_6М_Резчег# 
. й Исп ка Е 


ОНегРигспазедЕуепЕ 


{"ите": 166573752000, 
"уаНаТо": 166576752000} 


Рауета = "ИйспКа" 
ОНейа = "5Р_6 М Безег#ТгапзасНопТа" 


РХОМС (НЕ) Нньоваа" 


2 ДОМЕН РОБОТОВ ИГРОКА 


РХОМ!С (НЕ) Нньова" 


2 ДОМЕН РОБОТОВ ИГРОКА 


® Может быть много роботов одного типа 


РХОМ!С (НЕ) Нньова" 


=} ДОМЕН РОБОТОВ ИГРОКА 


КоБо{Е Ей Ку 
Ра оп Кеу Сиегта Кеу 


{"буре!а": эгтоа\ае, 
® Может быть много роботов одного типа 


Ра оп Кеу Сиегта Кеу 


{"буреТа": Без нпег, 
"|еме!": 1} 


Р!ауег Та ©1101 
Р!ауег Та Су1р2 


РХОМ!С (НЕ) Ниньова" 


{"буреТа": Без нпег, 
“еуе!": 5} 


=} КОНКУРЕНТНОЕ ДОБАВЛЕНИЕ РОБОТОВ —'`” 


Ргое 5ег\се 
Рауета = "Миска" 
аа 
КоБокАааедЕуегЕ Туре!а = "Безчег" 


Геуе! = 1 Са$запага 


} КоБо{ Епу 
Рагюп Кеу Си$егпд Кеу 


Ргое Зегмсе 


Коро{АаЧедЕуепе РНауета = "Ыйснка" 


КороНа = "Суто2" 
Туре!а = "Безёчег" 
Ёеуе! = 1 


РХОМ1!С НЕ) НЕноаа* 


2022 


=} КОНКУРЕНТНОЕ ДОБАВЛЕНИЕ РОБОТОВ 


Ргое 5ег\се 
Рауета = "Миска" 
аа 
КоБокАааедЕуегЕ Туре!а = "Безчег" 


Геме! = 1 Са$запага 


КоБо{ Епу 


Рагюп Кеу Си$егпд Кеу 


Нйспка 


Ргое $егмсе "|емЕ!": 1} 


КоБо{АааедЕуепЕ Рауета 


Нйспка 


"|еув!": 1} 


= "МИсбка" 

КороНа = "Суто2" 

Туре!а = "Безёчег" 
Ёеуе! = 1 


РХОМ!С 


{"фуре!а": "Резчег", 


{"фуре1а": "Резнчег", 


НЫ) НИГоаа** 


28 БИЗНЕС-СЦЕНАРИЙ «КУПИТЬ ОФФЕР» 


е Неидемпотентно 
® Можем выдать несколько роботов на одну покупку 


® Требуется синхронизация 


РХОМ!С (НЕ) Нньова" 


= ЧТО МЫ ИСПОЛЬЗУЕМ ДЛЯ СИНХРОНИЗАЦИИ 


е Распределенные локи ГоокКеерег 


® Е\епЕ очгста 


РХОМ!С (НЕ) Нньова" 


=} ЧУТЬ БОЛЕЕ РЕАЛЬНАЯ АРХИТЕКТУРА 


Балансировщик 


Нт 
Ргое 
бегусе 


е НТТР ]лауа-сервера 


е Саз5апага 


е Балансировщик Коипа КоБп НТТР 


Ргое 
бегусе 


Ргое 
бегмусе 


е Гоокеерег 


Р!ХОМ!С (НЕ) Нньова" 


2} ТРЕБОВАНИЯ БИЗНЕСА К ОФФЕРНОЙ 
СИСТЕМЕ МЕЧТЫ 


®_Выдаю-ЕЯ-Аю-разнинынннынм-е©бынтИЯНМ-ИЕРЮЖКа 
® Рассчитаны на разные группы игроков 

е Предлагают контент различного типа 

е 1000+ 


е Покупка как за внутриигровую валюту, так и за реальные деньги 


Р1ХОМ!С (НЕ) Ниньова" 


2} ТРЕБОВАНИЯ БИЗНЕСА К ОФФЕРНОЙ 
СИСТЕМЕ МЕЧТЫ 


®_Выдаю-ЕЯ-Аю-разнинынннынм-е©бынтИяЯНм-иЕРЮКа 


Ш} © Рассчитаны на разные группы игроков 
© Предлагают контент различного типа 
о 1000+ 


е Покупка как за внутриигровую валюту, так и за реальные деньги 


Р1ХОМ!С (НЕ) Ниньова" 


=} КРИТЕРИИ РАСПРЕДЕЛЕНИЯ В ГРУППЫ 


е Уровень игрока 

е Страна 

е Боевой рейтинг 

е Наличие робота/пушки,.... 

е Сумма платежей за последние М дней 
е Средний платеж за М дней 


е Количество дней без платежей 


РХОМ!С (НЕ) Ниньова" 


=} УСЛОВИЯ РАСПРЕДЕЛЕНИЯ ЧЕРЕЗ СКРИПТЫ 


СКОО\\У 


Гибкость, а не удобство 
е Защита данных 
о Адаптеры доменов 


О Ограничиваем доступ к классам и пакетам 


РХОМ!С 


(н.) НЕНЕоаа*" 


= КОНФИГ ГРУПП РАСПРЕДЕЛЕНИЯ 


50Ё_агеаег_5000 маек .зоЁ > 5000 
попеу_1е$$_{Нап15 р!ауег.5реп{Веа!Мопеу < 15 
[еадче_3200_3800 р!ауег.!еадие$согез > 3200 && р!ауег.|[еадие5согез < 3800 


р!ауег.зрепВеа!Мопеу\/НтрРау$(30) < 25 
топеу_25_50_по_Ауепдег && р!ауег.зрепВеа!Мопеу\\/ Е тВау$(30) < 50 
&& Папдаг.соипЕРогТуре('Ауепдег) == 


РХОМ!С (НЕ) Ниньова" 


= КОНФИГ ОФФЕРОВ 


о О ОНИ 


5Р_21\|_1000ач_40т5ой ОМ_ТЕ\МЕЁЕ_УР топеу_1е5$_{Нап15 
БР_4М| СИИ _падпит_{агап ОМ_ЕМТЕК_САКАСЕ 5о__адгеаег 5000 
5Р_5М| Г апсе!о*_огкап ОМ_КОВОТ_ОВТАТМ |еадче_3200_3800 


ЗР_6\М|_@СгИЯп_ТщитвБа$_рт ОМ_)01М_ 1ЕАСИЕ 


5Р_6\[_5000аи ОМ_\МТЕМ/ \ТРЕО_АБ 


5Р_7М1_Ригу_7еи$ ОМ_ВЕТУВКМ_РКОМ_ОРЕЫМЕ 


РХОМ!С (НЕ) Нньова" 


2} ТРЕБОВАНИЯ БИЗНЕСА К ОФФЕРНОЙ 
СИСТЕМЕ МЕЧТЫ 


®_Выдаю-ЕЯ-Аю-вазнинынннынм-е©бынтИЯНМ-ИЕРЮЖКа 
®_РаеЕчитанынна-разные-Ерунны-ин-рюкев 

® Предлагают контент различного типа 

ое 1000+ 


е Покупка как за внутриигровую валюту, так и за реальные деньги 


Р1ХОМ!С (НЕ) Ниньова" 


2} ТРЕБОВАНИЯ БИЗНЕСА К ОФФЕРНОЙ 
СИСТЕМЕ МЕЧТЫ 


®_Выдаю-тЕЯ-Аю-вазнинынНнынм-е©бынРИЯНМ-ИЕРЮЖКа 
®_РаеЕчитанын-на-вазнныке-РРАуЕННЫНУНРеев 


=» ® Предлагают контент различного типа 
ое 1000+ 


е Покупка как за внутриигровую валюту, так и за реальные деньги 


Р1ХОМ!С (НЕ) Ниньова" 


=} ТРЕБОВАНИЯ К КОНТЕНТУ 


е Легко расширяется 
е Легко конфигурируется 


е® Может быть переиспользован 


РХОМ!С (НЕ) Ниньова" 


=} ДИАГРАММА КЛАССОВ ПРОТОТИПОВ 


СопепЕРго{о 


СиггепсуРго*о 


со4е: тд 
аточцпе: 0п9 


\М/еаропРгоо 


фуре1а: тд 
[еме!: т 


ВоБо{Ргоо 


фуре!а: тд 

1еме!: 1пё 

гапк: пе 

м!еаропз: ${<\/еаропСотепЕРго{о > 


РХОМ!С (НЕ) Нньова" 


=} ДИАГРАММА КЛАССОВ ПРОЦЕССОРОВ 
КОНТЕНТА 


ЦетКем/агаРгосе$$ог 


+91\е(ргофо: СопепЕРгоко) 


\М/еаропКем/агаРгосе$5ог 


+91\е(ргофо: ММеаропРгоко) 


Воро{ВемагарРгосе$5ог 


+9!\е(ргото: КоБо{Ргофо) 


СиггепсуВе\магаРгосе$$ог 


+9!\е(ргото: СиггепсуРгоо) 


РХОМ!С (НЕ) Ниньова" 


= КОЛЛЕКТОР КОНТЕНТА 


Сог(епРго{оКемагаСоПесвог 


Реестр процессоров 
СиггепсуВемагаРгосе$$5ог 


\\еаропВем/агаРгосе$5ог 
Кобо*ВемагаРгосе$$ог 


[_] соиесе 


РХОМС (НЕ) Ниньова" 


15 КОЛЛЕКТОР КОНТЕНТА о В ое рае 


Добавить СопеепЕРгою 


® Добавить ЦетКе\м/агаРгосе$$ог 
еестр процессоров 


\\еаропВем/агаРгосе$5ог 
Кобо*ВемагаРгосе$$ог 


[_] соиесе 


РХОМС (НЕ) Нньова" 


= КОНФИГ КОНТЕНТА 


40тАд сиггепсу Ад 40 000 000 
1КАц сиггепсу Ач 1000 
Еапсе!о{_\№1_1_1 гоБо{ Еапсе!о__\/1 1 
Ауепдег_\/1_1_1 меароп Ауепдег _\1 1 
Тиитвба$_\/1_12_1 меароп Тиитвба$_\1 12 


РХОМ!С (НЕ) Нньова" 


= КОНФИГ ОФФЕРОВ 


5Р_21\|_1000аи_40т$0Ё ОМ_ТЕМЕЕ_УР попеу_[е5$_{Пеп15 40тАд, 1КАц 
5Р_4М_СгИЯп_падпит{агап ОМ_ЕМТЕК _САКАСЕ 50Ё_одгеакег_5000 
5Р_5М| Г апсе!о*_огкап ОМ_КОВОТ_ОВТА1М [еадие_3200_3800 Гапсе!о*_\1_1_1 


ЗР_6\М|_@СгИЯп_ТщитвБа$_рт ОМ_)01М_ 1ЕАСИЕ 


Ауепдег_\1_1_1, 


5Р_6\[_5000ац ОМ_\МТЕМ/_\ТРЕО_АБ ТиитьБа$_\1_12_1 


5Р_7М_Ригу_7еи$ ОМ_ВЕТУВКМ_РКОМ_ОРЕРЫМЕ 


РХОМ!С (НЕ) Нньоаа" 


2} ТРЕБОВАНИЯ БИЗНЕСА К ОФФЕРНОЙ 
СИСТЕМЕ МЕЧТЫ 


®_Выдаютея-лю-разяичнным-еебыиям-иррека 
е—Раеечитаньнна-разные-Еруны-иерекев 

+ _Нредяараю- контен--разяичненре-тиа 

о 1000+ 


е Покупка как за внутриигровую валюту, так и за реальные деньги 


РХОМ!С (НЕ) Ниньова" 


2} ТРЕБОВАНИЯ БИЗНЕСА К ОФФЕРНОЙ 
СИСТЕМЕ МЕЧТЫ 


®_Выдаютея-ю-разяичнным-еебыиям-иррека 
е—Раеечичаньнна-разные-Ерунны-иерекев 
+ _Нредяараю- контен--разяичненре-тиа 

Ш} ‹ 1000+ 


е Покупка как за внутриигровую валюту, так и за реальные деньги 


РХОМ!С (НЕ) Ниньова" 


2 ОПТИМИЗАЦИЯ ФИЛЬТРАЦИИ ОФФЕРОВ '’’`” 


Офферов 1000+ 
ССУ ЗоК 


РАХОМ!С Фаны 


= КОНФИГ ОФФЕРОВ 


5Р_2М_1000ацч_40т$5оЁ ОМ_ГЕМЕЕ_УР топеу_1е5$_{Пеп15 40тАд, 1КАц 27.10.2022 9:00 28.10.2022 9:00 
ЗР_4/М|_СгИЯп_падпит_агап ОМ_ЕМТЕВ _САКАСЕ 5оВ_дгеа{ег_5000 4 27.10.2022 9:00 28.10.2022 9:00 
ЗР_5М| [Г апсе!о{_ огКап ОМ_КОВОТ_ОВТА1М 1еадие_3200_3800 ГапсеоЕ_\№\1_1_1 5 27.10.2022 9:00 
ЗР_6 М _СгИИп_ТиитБа$_рт ОМ_201М_ТЕАСУЕ 6 27.10.2022 9:00 


А\уепдег_\1_1_1, 


Тиитьаз №1 121 6 27.10.2022 9:00 


ЗР_6№М_5000аи ОМ_М\МТЕМ/_МТРЕО_АБ 


5Р_7М_Ригу_7еи$ ОМ_КВЕТУВМ_РКОМ_ОРЕЫМЕ 7 27.10.2022 9:00 


РХОМ!С НЕ) Наньоаа"" 


= ОПТИМИЗАЦИЯ РАБОТЫ С КОНФИГОМ 


е Все конфиги в памяти 
® Сгооуу-скрипты также в памяти 


е Конфиг в цчо\/ 


РХОМ!С (НЕ) Ниньова" 


&} СХЕМА СОЗДАНИЯ ЧМТ ОЕ МОВК 


Провайдер конфига Уп оЁ М/огк Расеогу 
[слет вони" [ 


Р1ХОМ!С (НЕ) Ниньова" 


= СХЕМА СОЗДАНИЯ ЧМТ ОЕ МОВК 


Провайдер конфига Уп оЁ М/огк Расеогу 


П-Ю 


Р1ХОМ!С (НЕ) Ниньова" 


=} СХЕМА СОЗДАНИЯ ЧМТ ОЕ МОВК 


Провайдер конфига Уп оЁ М/огк Расеогу 


РАХОМ!С (НЕ) Ниньова" 


П-Ю 


Версия 


=} СХЕМА СОЗДАНИЯ ЧМТ ОЕ МОВК 


Провайдер конфига Уп оЁ М/огк Расеогу УпЁ оЁ Могк 
езЕзнинииЫ |‘ иниаанении — 


Провайдер конфига 


РАХОМ!С (НЕ) Нньова" 


С == 


Версия 


= ОПТИМИЗАЦИЯ РАБОТЫ С ДАННЫМИ ИГРОКА 


е Распределенный кэш 


Керо$Когу 
= 


Р1ХОМ!С (НЕ) Нньова" 


=} ПРИМЕРЫ ПОПАДАНИЯ В КЭШ НА ДОМЕНАХ 


СасНе НИВае 


0.700 
0.600 
0.500 
0.400 
0.300 


0.200 
10/16 12:00 10/16 18:00 10/17 00:00 10/17 06:00 10/17 12:00 10/17 18:00 10/18 00:00 10/18 06:00 
> Р!ауегОНегВеро$Цогу == \/9ОЙегКеро$Когу == Моди|еКеро $Когу 


=} ПРИМЕРЫ ПОПАДАНИЯ В КЭШ НА ДОМЕНАХ 


СасНе НИВае 


0.700 
0.600 
0.500 
0.400 
0.300 


0.200 
10/16 12:00 10/16 18:00 10/17 00:00 10/17 06:00 10/17 12:00 10/17 18:00 10/18 00:00 10/18 06:00 
= Р!ауегОНегВеро$Цогу == \/9ОЙегКеро$Когу == Моди|еКеро $Когу 


=} ПРИМЕРЫ ПОПАДАНИЯ В КЭШ НА ДОМЕНАХ 


СасНе НИВае 


0.700 
0.600 
0.500 
0.400 
0.300 


0.200 
10/16 12:00 10/16 18:00 10/17 00:00 10/17 06:00 10/17 12:00 10/17 18:00 10/18 00:00 10/18 06:00 
= Р!ауегОНегВеро$Цогу == \/9ОЙегКеро$Когу == Моди|еКеро $Когу 


=} ПРИМЕРЫ ПОПАДАНИЯ В КЭШ НА ДОМЕНАХ 


СасНе НИВае 


0.700 
0.600 
0.500 
0.400 
0.300 


0.200 
10/16 12:00 10/16 18:00 10/17 00:00 10/17 06:00 10/17 12:00 10/17 18:00 10/18 00:00 10/18 06:00 
= Р!ауегОНегВеро$Цогу == \/9ОЙегКеро$Когу == Моди|еКеро $Когу 


= ПРИМЕРЫ ПОПАДАНИЯ В КЭШ НА ДОМЕНАХ 


СасНе НИВае 


1 


ид нь ие оттито оо Ур Ач ре ту нь ры 


—» 
|| 


| 


/ фед ечиовьт АЛУТу чм еичичич т 


0.900 
0.800 
0.700 
0.600 
0.500 
0.400 
0.300 


0.200 
10/16 12:00 10/16 18:00 10/17 00:00 10/17 06:00 10/17 12:00 10/17 18:00 10/18 00:00 10/18 06:00 


= Р|ауегОНегВеро${огу == \/|9ОЙегВерозИогу == МодиеВеро $Когу 


= ПРИМЕРЫ ПОПАДАНИЯ В КЭШ НА ДОМЕНАХ 


СасНе НИВае 


1 


ид рр идиом А чет рн ту нь ры 


—» 
|| 


| 


/ фото ед ечиовь АПУТУ о ааа ечечич т 


0.900 


м уму и] 
0.800 ый — ыы аа 
ее" мА 
0.700 Г” 
0.600 
ри и 
0.500 | | 
0.400 | 
0.300 


0.200 
10/16 12:00 10/16 18:00 10/17 00:00 10/17 06:00 10/17 12:00 10/17 18:00 10/18 00:00 10/18 06:00 


= Р|ауегоНегКеро$огу == \У/дОЙегРеро$Йогу == Моди|еКеро $Когу 


=} ТЕКУЩАЯ НАГРУЗКА 


Меап КР$ 

е 120 ор5/5ес 
Мах ВР$ 

е 321 ор5/5ес 


РХОМ!С 


10/10 09:00 


= ргод 


10/10 12:00 


10/10 15:00 


АР! Ведиез{$ {о ВасКеп4 1п${апсе рег 5т 


10/10 18:00 


10/10 21:00 


10/11 00:00 


10/11 03:00 


10/11 06:00 


| 

| 

| 

| 

| 

\ 

| 

-] 
10/11 09:00 

Меап Газ * 
351К 36.7К 


НЫ) НИГоаа** 


=} ТЕКУЩАЯ НАГРУЗКА 


АР! Ведиез{$ {о ВасКеп4 1п${апсе рег 5т 


Меап ВР$ и 


110К 


е 120 ор5/зес *", \ 
Мах КР$ 7ок | 


® 321 ор5/зес * |“. ыы 


10/10 09:00 10/10 12:00 10/10 15:00 10/10 18:00 10/10 21:00 10/11 00:00 10/11 03:00 10/11 06:00 10/11 09:00 


Меап Газ * 
351К 36.7К 


= ргод 


РХОМ1!С НЕ) НЕньоаа* 


=} ТАТЕМСУ ЗАПРОСОВ КЛИЕНТА К ОФФЕРАМ 
СНеп{ АР! а{епсу 99р: ОНег$ 


200 т$ 


И НИ У и И М У У И | 


:00 


Меап Мах 


2} ТАТЕМСУ ЗАПРОСОВ КЛИЕНТА К ОФФЕРАМ 


СИег{ АР! а{епсу 99р: ОНег$ 


200 т$ 


| 
=. М м А М У У И 


2 КОРРЕЛЯЦИЯ ЗАПРОСА ЛОББИ С ОФФЕРАМИ 


СНеп! АР!Га{епсу 99р: багаде 


10/15 09:00 10/15 12:00 10/15 15:00 10/15 18:00 10/15 21:00 10/16 00:00 10/16 03:00 10/16 06:00 10/16 09:00 10/16 12:00 
Меап Мах 


586 тз 1.07$ 
746 т5 864 т$ 


= ар/дагаде2? 


= оНегсаспе ПК гае 


2 КОРРЕЛЯЦИЯ ЗАПРОСА ЛОББИ С ОФФЕРАМИ 


СНег( АР! аепсу 99р: багаде 


10/15 09:00 10/15 12:00 10/15 15:00 10/15 18:00 10/15 21:00 10/16 00:00 10/16 03:00 10/16 06:00 10/16 09:00 10/16 12:00 
Меап Мах 


— ар/дагаде2 586 м5 1.07$ 
оЙег саспе ПИ ге 746 т5 864 т$ 


2 КОРРЕЛЯЦИЯ ЗАПРОСА ЛОББИ С ОФФЕРАМИ 


СНеп! АР!Га{епсу 99р: Сагаде 


10/15 09:00 10/15 12:00 10/15 15:00 10/15 18:00 10/15 21:00 10/16 00:00 10/16 03:00 10/16 06:00 10/16 09:00 10/16 12:00 
Меап Мах 


= ар/дагаде? 586 тз 1.07$ 
оПег саспе ПИ гае 746 т$ 864 т5 


2} ТРЕБОВАНИЯ БИЗНЕСА К ОФФЕРНОЙ 
СИСТЕМЕ МЕЧТЫ 


®_Выдаютея-лю-разяичнным-еебыиям-иррека 
е—Раеечитаньнна-разные-Еруны-иерекев 
+ _Нредяараю- контен--разяичненре-тиа 
э®-+00909-- 


е Покупка как за внутриигровую валюту, так и за реальные деньги 


РХОМ!С (НЕ) Ниньова" 


2} ТРЕБОВАНИЯ БИЗНЕСА К ОФФЕРНОЙ 
СИСТЕМЕ МЕЧТЫ 


®_Выдаютея-лю-разяичнным-еебыиям-иррека 
е—Раеечитаньнна-разные-Еруны-иерекев 
+ _Нредяараю- контен--разяичненре-тиа 
э®-+00909-- 


=» е Покупка как за внутриигровую валюту, так и за реальные деньги 


РХОМ!С (НЕ) Ниньова" 


=} ИНТЕГРАЦИЯ С ПЛАТЕЖАМИ 


6 Арр юге № соодеРьу атТахоп 
АЙ мислмес ° $ТЕАМ" 


Р1ХОМ!С (мня 


= ПРОЦЕСС ПОКУПКИ 


| Рго4исе Та | 


РХОМ!С (НЕ) Нньова" 


= ПРОЦЕСС ПОКУПКИ 


Рго4исе Та 


| | Оплата 


Квитанция | 


РХОМ!С (НЕ) Нньова" 


= ПРОЦЕСС ПОКУПКИ 


Рго4исе Та 


| | Оплата 
Квитанция 


Квитанция 


Выдача 
покупки 


РХОМ!С (НЕ) Ниньова" 


= ИВЧЕМ ЖЕ ПРОБЛЕМА? 


е Человеческие ошибки 
е Время на банковскую операцию 


е Недоступность магазинов 


РХОМ!С (НЕ) Ниньова" 


=} ТЕКУЩАЯ СХЕМА ПРОЦЕССА ПОКУПКИ 


<#> < ® 


Инициализация покупки 


РХОМ!С (НЕ) Ниньова" 


=} ТЕКУЩАЯ СХЕМА ПРОЦЕССА ПОКУПКИ 


= <= ® 


Инициализация покупки 


Сохранение снепшота 
14 снепшота продукта 


РХОМ!С (НЕ) Нньова" 


=} ТЕКУЩАЯ СХЕМА ПРОЦЕССА ПОКУПКИ 


= 9» ® 


Инициализация покупки 


! Сохранение снепшота 
14 снепшота продукта 


РгодисЕ ТА + Та снепшота 1 


РХОМ!С (НЕ) Нньова" 


=} ТЕКУЩАЯ СХЕМА ПРОЦЕССА ПОКУПКИ 


<> 9» ® 


1 Инициализация покупки 1 


Сохранение снепшота 
продукта 


| 
ТА снепшота 


Оплата 
Квитанция 


РХОМ!С (НЕ) Нньова" 


&} ТЕКУЩАЯ СХЕМА ПРОЦЕССА ПОКУПКИ 


<> =» ® 


1 Инициализация покупки 1 


| 
ТА снепшота 


Сохранение снепшота 
продукта 
РгодчсЕ ТА + 14а снепшота 


Оплата 
Квитанция 


Квитанция 


Поиск снепшота 
продукта 


Выдача покупки 


РХОМ!С (НЕ) Нньова" 


=} ЗАЩИТА ОТ НЕЧЕСТНЫХ ИГРОКОВ 


РАХОМ!С (НЕ) Нньова" 


2} ТРЕБОВАНИЯ БИЗНЕСА К ОФФЕРНОЙ 
СИСТЕМЕ МЕЧТЫ 


РХОМ!С (НЕ) Ниньова" 


=} РЕЗУЛЬТАТ 


е Легко заводить новые офферы 
е® Можно задавать сложные условия выдачи 
е Универсальные механизмы конфигурирования контента 


е Минимальное участие разработчика при добавлении нового 
контента 


® Скорость 


РХОМ!С (НЕ) Нньова" 


=} ВЫРУЧКА 2017-2022 


РХОМ!С НЕ) Неноаа"* 


=} ВЫРУЧКА 2017-2022 


А м т А 
+ ] 


®Ф-з! Ф оНег 


РАХОМ!С НГ) ненова- 


=} ВЫРУЧКА 2017-2022 


ны р ыы ыы 


01 лап 


®Ф-:! Фон ФЗ 


РАХОМ!С НГ) Нивиоаа" 


=} ТОЧКИ РОСТА 


Оптимизация работы команды монетизации 


® Выдача офферов игрока с помощью алгоритмов машинного 
обучения 


Пессимистичные блокировки 
® Внедрение аККа-кластера с шардированием по игроку 
Распределенный кэш данных игрока 


е Синхронизация алгоритмов распределения и обработки данных 


РХОМ!С (НЕ) Нньова" 


#2 ВЫВОДЫ 


е Всегда прорабатывать сценарии конкурентного доступа 


® Всегда искать пути оптимизации 


е Нет смысла сразу делать сложно и хайлоад 


РХОМ!С 


(н.) НЕНЕоаа*" 


Р1ХОМ!С 
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Обратная связь 
и комментарии 
по докладу по ссылке 


Наша игра 
/\ММАВВОВОТ$ СОМ 


Й (нь) --- ммм 


р 


